home *** CD-ROM | disk | FTP | other *** search
/ Software of the Month Club 2000 October / Software of the Month - Ultimate Collection Shareware 277.iso / pc / PROGRAMS / UTILITY / WINLINUX / DATA1.CAB / usr_-_Usr_Files / INCLUDE / FCNTL.H < prev    next >
Encoding:
C/C++ Source or Header  |  1999-09-17  |  2.6 KB  |  73 lines

  1. /* Copyright (C) 1991, 1992, 1994 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3.  
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Library General Public License as
  6. published by the Free Software Foundation; either version 2 of the
  7. License, or (at your option) any later version.
  8.  
  9. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  12. Library General Public License for more details.
  13.  
  14. You should have received a copy of the GNU Library General Public
  15. License along with the GNU C Library; see the file COPYING.LIB.  If
  16. not, write to the, 1992 Free Software Foundation, Inc., 675 Mass Ave,
  17. Cambridge, MA 02139, USA.  */
  18.  
  19. /*
  20.  *    POSIX Standard: 6.5 File Control Operations    <fcntl.h>
  21.  */
  22.  
  23. #ifndef _FCNTL_H
  24. #define _FCNTL_H
  25.  
  26. #include <features.h>
  27. #include <sys/types.h>
  28. #include <gnu/types.h>
  29. #include <linux/fcntl.h>
  30.  
  31. #ifndef FNDELAY
  32. #define FNDELAY    O_NDELAY
  33. #endif
  34.  
  35. __BEGIN_DECLS
  36.  
  37. /* Create and open FILE, with mode MODE.
  38.    This takes an `int' MODE argument because that is
  39.    what `mode_t' will be widened to.  */
  40. extern int creat __P ((__const char * __filename, mode_t __mode));
  41.  
  42. /* Do the file control operation described by CMD on FD.
  43.    The remaining arguments are interpreted depending on CMD.  */
  44. extern int fcntl __P ((int __fildes,int __cmd, ...));
  45. extern int __fcntl __P ((int __fildes,int __cmd, ...));
  46.  
  47. /* Open FILE and return a new file descriptor for it, or -1 on error.
  48.    OFLAG determines the type of access used.  If O_CREAT is on OFLAG,
  49.    the third argument is taken as a `mode_t', the mode of the created file.  */
  50. extern int open __P ((__const char * __filename, int __flags, ...));
  51. extern int __open __P ((__const char * __filename, int __flags, ...));
  52.  
  53. #if defined (__USE_MISC) && !defined (F_LOCK)
  54. /* NOTE: These declarations also appear in <unistd.h>; be sure to keep both
  55.    files consistent.  Some systems have them there and some here, and some
  56.    software depends on the macros being defined without including both.  */
  57.  
  58. /* `lockf' is a simpler interface to the locking facilities of `fcntl'.
  59.    LEN is always relative to the current file position.
  60.    The CMD argument is one of the following.  */
  61.  
  62. #define F_ULOCK 0    /* Unlock a previously locked region.  */
  63. #define F_LOCK  1    /* Lock a region for exclusive use.  */
  64. #define F_TLOCK 2    /* Test and lock a region for exclusive use.  */
  65. #define F_TEST  3    /* Test a region for other processes locks.  */
  66.  
  67. extern int lockf __P ((int __fd, int __cmd, __off_t __len));
  68. #endif
  69.  
  70. __END_DECLS
  71.  
  72. #endif
  73.